<!--
~  Licensed to the Apache Software Foundation (ASF) under one or more
~  contributor license agreements.  See the NOTICE file distributed with
~  this work for additional information regarding copyright ownership.
~  The ASF licenses this file to You under the Apache License, Version 2.0
~  (the "License"); you may not use this file except in compliance with
~  the License.  You may obtain a copy of the License at
~
~     http://www.apache.org/licenses/LICENSE-2.0
~
~  Unless required by applicable law or agreed to in writing, software
~  distributed under the License is distributed on an "AS IS" BASIS,
~  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
~  See the License for the specific language governing permissions and
~  limitations under the License.
-->

<div class="flex flex-col flex-1 h-full gap-y-2">
    <div class="listing-table select-none flex flex-1 h-full">
        <div class="flex-1 relative">
            <div class="absolute inset-0 overflow-y-auto overflow-x-hidden">
                <table
                    mat-table
                    [dataSource]="dataSource"
                    matSort
                    matSortDisableClear
                    (matSortChange)="sortData($event)"
                    [matSortActive]="sort.active"
                    [matSortDirection]="sort.direction">
                    <!-- Name Column -->
                    <ng-container matColumnDef="name">
                        <th mat-header-cell *matHeaderCellDef mat-sort-header>Name</th>
                        <td mat-cell *matCellDef="let item">
                            <div class="overflow-ellipsis overflow-hidden whitespace-nowrap" [title]="item.name">
                                {{ item.name }}
                            </div>
                        </td>
                    </ng-container>
                    <!-- Description Column -->
                    <ng-container matColumnDef="description">
                        <th mat-header-cell *matHeaderCellDef mat-sort-header>Description</th>
                        <td mat-cell *matCellDef="let item">
                            <div class="overflow-ellipsis overflow-hidden whitespace-nowrap" [title]="item.description">
                                {{ item.description }}
                            </div>
                        </td>
                    </ng-container>
                    <!-- Identifier Column -->
                    <ng-container matColumnDef="identifier">
                        <th mat-header-cell *matHeaderCellDef mat-sort-header>Bucket ID</th>
                        <td mat-cell *matCellDef="let item">
                            <div class="overflow-ellipsis overflow-hidden whitespace-nowrap" [title]="item.identifier">
                                {{ item.identifier }}
                            </div>
                        </td>
                    </ng-container>
                    <!-- Actions Column -->
                    <ng-container matColumnDef="actions">
                        <th mat-header-cell *matHeaderCellDef></th>
                        <td mat-cell *matCellDef="let item">
                            <div class="flex items-center justify-end gap-x-2">
                                <button
                                    mat-icon-button
                                    type="button"
                                    [matMenuTriggerFor]="actionMenu"
                                    class="h-16 w-16 flex items-center justify-center icon global-menu">
                                    <i class="fa fa-ellipsis-v"></i>
                                </button>
                                <mat-menu #actionMenu="matMenu" xPosition="before">
                                    <button mat-menu-item (click)="openEditBucketDialog(item)">Edit</button>
                                    <button mat-menu-item (click)="openManageBucketPoliciesDialog(item)">
                                        Manage Policies
                                    </button>
                                    <button mat-menu-item (click)="openDeleteBucketDialog(item)">Delete</button>
                                </mat-menu>
                            </div>
                        </td>
                    </ng-container>
                    <tr mat-header-row *matHeaderRowDef="displayedColumns; sticky: true"></tr>
                    <tr
                        mat-row
                        *matRowDef="let row; let even = even; columns: displayedColumns"
                        [class.even]="even"
                        (click)="select(row)"
                        [class.selected]="isSelected(row)"></tr>
                </table>
            </div>
        </div>
    </div>
</div>
